home *** CD-ROM | disk | FTP | other *** search
/ Java Interactive Reference Guide / Java Interactive Reference Guide.iso / autorun / java_d.dir / 00246_Field_15.txt < prev    next >
Text File  |  1980-01-11  |  12KB  |  478 lines

  1. 8 Statements
  2.  
  3.  
  4. ---------------------------------------------------------
  5.  
  6.  
  7. 8.1 - Declarations
  8.  
  9.  
  10.  
  11. 8.2 - Expressions
  12.  
  13.  
  14.  
  15. 8.3 - Control Flow
  16.  
  17.  
  18.  
  19. 8.4 - Exceptions
  20.  
  21.  
  22.  
  23.  
  24. 8.4.1 - The finally Statement
  25.  
  26.  
  27.  
  28. 8.4.2 - Runtime Exceptions
  29.  
  30.  
  31.  
  32.  
  33.  
  34. ---------------------------------------------------------
  35.  
  36. 8.1 Declarations
  37.  
  38. Declarations can appear anywhere that a statement is allowed. The scope of the declaration ends at the end of the enclosing block.
  39.  
  40. In addition, declarations are allowed at the head of for statements, as shown below:
  41.  
  42.  
  43.  
  44.  
  45.     for (int i = 0; i < 10; i++) {
  46.         ...
  47.     }
  48.  
  49.  
  50.  
  51. Items declared in this way are valid only within the scope of the for statement. For example, the preceding code sample is equivalent to the following:
  52.  
  53.  
  54.  
  55.  
  56.     {
  57.         int i = 0;
  58.         for (; i < 10; i++) {
  59.         ...
  60.         }
  61.     }
  62.  
  63.  
  64.  
  65.  
  66. ---------------------------------------------------------
  67.  
  68.  
  69. 8.2 Expressions
  70.  
  71. Expressions are statements: 
  72.  
  73.  
  74.  
  75.  
  76.     a = 3;
  77.     print(23);
  78.     foo.bar();
  79.  
  80.  
  81.  
  82.  
  83. ---------------------------------------------------------
  84.  
  85.  
  86. 8.3 Control Flow
  87.  
  88. The following is a summary of control flow:
  89.  
  90.  
  91.  
  92.  
  93. if(boolean) statement
  94. else statement
  95. switch(e1) {
  96.     case e2: statements
  97.     default: statements
  98. }
  99. break [label];
  100. continue [label];
  101. return e1;
  102. for([e1]; [e2]; [e3]) statement
  103. while(boolean) statement
  104. do statement while(boolean);
  105. label:statement
  106.  
  107.  
  108.  
  109. The language supports labeled loops and labeled breaks, for example: 
  110.  
  111.  
  112.  
  113.  
  114.     outer:   // the label
  115.         for (int i = 0; i < 10; i++) {
  116.             for (int j= 0; j< 10; j++) {
  117.                 if (...) {
  118.                     break outer;
  119.                 }
  120.                 if (...) {
  121.                 }
  122.             }
  123.     }
  124.  
  125.  
  126.  
  127. The use of labels in loops and breaks has the following rules:
  128.  
  129.  
  130.  
  131. ΓÇóAny statement can have a label.
  132.  
  133. ΓÇóIf a break statement has a label it must be the label of an enclosing statement.
  134.  
  135. ΓÇóIf a continue statement has a label it must be the label of an enclosing loop.
  136.  
  137.  
  138.  
  139.  
  140. ---------------------------------------------------------
  141.  
  142.  
  143. 8.4 Exceptions
  144.  
  145. When an error occurs in an Java program--for example, when an argument has an invalid value--the code that detects the error can throw an exception*1. By default, exceptions result in the thread terminating after printing an error message. However, programs can have exception handlers that catch the exception and recover from the error. 
  146.  
  147. Some exceptions are thrown by the Java runtime system. However, any class can define its own exceptions and cause them to occur using throw statements. A throw statement consists of the throw keyword followed by an object. By convention, the object should be an instance of Exception or one of its subclasses. The throw statement causes execution to switch to the appropriate exception handler. When a throw statement is executed, any code following it is not executed, and no value is returned by its enclosing method. The following example shows how to create a subclass of Exception and throw an exception.
  148.  
  149.  
  150.  
  151.  
  152.     class MyException extends Exception {
  153.     }
  154.  
  155.     class MyClass {
  156.         void oops() {
  157.             if (/* no error occurred */) {
  158.                 ...
  159.             } else { /* error occurred */
  160.             throw new MyException();
  161.             }
  162.         }
  163.     }
  164.  
  165.  
  166.  
  167. To define an exception handler, the program must first surround the code that can cause the exception with a try statement. After the try statement come one or more catch statements--one per exception class that the program can handle at that point. In each catch statement is exception handling code. For example:
  168.  
  169.  
  170.  
  171.  
  172.     try {
  173.         p.a = 10;
  174.     } catch (NullPointerException e) {
  175.         println("p was null");
  176.     } catch (Exception e) {
  177.         println("other error occurred");
  178.     } catch (Object obj) {
  179.         println("Who threw that object?");
  180.     }
  181.  
  182.  
  183.  
  184. A catch statement is like a method definition with exactly one parameter and no return type. The parameter can be either a class or an interface. When an exception occurs, the nested try/catch statements are searched for a parameter that matches the exception class. The parameter is said to match the exception if it:
  185.  
  186.  
  187.  
  188. ΓÇóis the same class as the exception; or
  189.  
  190. ΓÇóis a superclass of the exception; or
  191.  
  192. ΓÇóif the parameter is an interface, the exception class implements the interface.
  193.  
  194.  
  195.  
  196. The first try/catch statement that has a parameter that matches the exception has its catch statement executed. After the catch statement executes, execution resumes after the try/catch statement. It is not possible for an exception handler to resume execution at the point that the exception occurred. For example, this code fragment:
  197.  
  198.  
  199.  
  200.  
  201.     print("now ");
  202.     try {
  203.         print("is ");
  204.         throw new MyException();
  205.         print("a ");
  206.     } catch(MyException e) {
  207.         print("the ");
  208.     }
  209.     print("time\n");
  210.  
  211.  
  212.  
  213. prints "now is the time". As this example shows, exceptions don't have to be used only for error handling, but any other use is likely to result in code that's hard to understand. 
  214.  
  215. Exception handlers can be nested, allowing exception handling to happen in more than one place. Nested exception handling is often used when the first handler can't recover completely from the error, yet needs to execute some cleanup code (as shown in the following code example). To pass exception handling up to the next higher handler, use the throw keyword using the same object that was caught. Note that the method that rethrows the exception stops executing after the throw statement; it never returns. 
  216.  
  217.  
  218.  
  219.  
  220.     try {
  221.         f.open();
  222.     } catch(Exception e) {
  223.         f.close();
  224.         throw e;
  225.     }
  226.  
  227.  
  228.  
  229.  
  230. ---------------------------------------------------------
  231.  
  232.  
  233. 8.4.1 The finally Statement
  234.  
  235. The following example shows the use of a finally statement that is useful for guaranteeing that some code gets executed whether or not an exception occurs. You can use either a catch statement or a finally statement within a particular try block, but not both. For example, the following code example:
  236.  
  237.  
  238.  
  239.  
  240.     try {
  241.         // do something
  242.     } finally {
  243.         // clean up after it
  244.     }
  245.  
  246.  
  247.  
  248. is similar to:
  249.  
  250.  
  251.  
  252.  
  253.     try {
  254.         // do something
  255.     } catch(Object e){
  256.         // clean up after it
  257.         throw e;
  258.     }
  259.     // clean up after it
  260.  
  261.  
  262.  
  263. The finally statement is executed even if the try block contains a return, break, continue, or throw statement. For example, the following code example always results in "finally" being printed, but "after try" is printed only if a != 10.
  264.  
  265.  
  266.  
  267.  
  268.     try {
  269.         if (a == 10) {
  270.             return;
  271.         }
  272.     } finally {
  273.         print("finally\n");
  274.     }
  275.     print("after try\n");
  276.  
  277.  
  278.  
  279.  
  280. ---------------------------------------------------------
  281.  
  282.  
  283. 8.4.2 Runtime Exceptions
  284.  
  285. This section contains a list of the exceptions that the Java runtime throws when it encounters various errors.
  286.  
  287. ArithmeticException
  288.  
  289. Attempting to divide an integer by zero throws the ArithmeticException--no other arithmetic operation in Java throws an exception. For information on how Java handles other arithmetic errors see "Operators on Integers" on page 26 and "Operators on Floating Point Values" on page 28. 
  290.  
  291. For example, the following code causes an ArithmeticException to be thrown:
  292.  
  293.  
  294.  
  295.  
  296.     class Arith {
  297.         public static void main(String args[]) {
  298.             int j = 0;
  299.             j = j / j;
  300.         }
  301.     }
  302.  
  303.  
  304.  
  305. NullPointerException
  306.  
  307. An attempt to access a variable or method in a null object or a element in a null array throws a NullPointerException. For example, the accesses o.length and a[0] in the following class declaration throws a NullPointerException at runtime.
  308.  
  309.  
  310.  
  311.  
  312.     class Null {
  313.         public static void main(String args[]) {
  314.             String o = null;
  315.             int a[] = null;
  316.             o.length();
  317.             a[0] = 0;
  318.         }
  319.     }
  320.  
  321.  
  322.  
  323. It is interesting to note that if you throw a null object you actually throw a NullPointerException.
  324.  
  325. IncompatibleClassChangeException
  326.  
  327. In general the IncompatibleClassChangeException is thrown whenever one class's definition changes but other classes that reference the first class aren't recompiled. Four specific changes that throw a IncompatibleClassChangeException at rutime are: 
  328.  
  329.  
  330.  
  331. ΓÇóA variable's declaration is changed from static to non-static in one class but other classes that access the changed variable aren't recompiled.
  332.  
  333. ΓÇóA variable's declaration is changed from non-static to static in one class but other classes that access the changed variable aren't recompiled.
  334.  
  335. ΓÇóA field that is declared in one class is deleted but other classes that access the field aren't recompiled. 
  336.  
  337. ΓÇóA method that is declared in one class is deleted but other classes that access the method aren't recompiled. 
  338.  
  339.  
  340.  
  341. ClassCastException
  342.  
  343. A ClassCastException is thrown if an attempt is made to cast an object O into a class C and O is neither C nor a subclass of C. For more information on casting see "Casting Between Class Types" on page 12.
  344.  
  345. The following class declaration results in a ClassCastException at runtime:
  346.  
  347.  
  348.  
  349.  
  350.     class ClassCast {
  351.         public static void main(String args[]) {
  352.             Object o = new Object();
  353.             String s = (String)o;           // the cast attempt
  354.             s.length();
  355.         }
  356.     }
  357.  
  358.  
  359.  
  360. NegativeArraySizeException
  361.  
  362. A NegativeArraySizeException is thrown if an array is created with a negative size. For example, the following class definition throws a NegativeArraySizeException at runtime:
  363.  
  364.  
  365.  
  366.  
  367.     class NegArray {
  368.         public static void main(String args[]) {
  369.             int a[] = new int[-1];
  370.             a[0] = 0;
  371.         }
  372.     }
  373.  
  374.  
  375.  
  376. OutOfMemoryException
  377.  
  378. An OutOfMemoryException is thrown when the system can no longer suppy the application with memory. The OutOfMemoryException can only occur during the creation of an object, i.e., when new is called. For example, the following code results in an OutOfMemoryException at runtime:
  379.  
  380.  
  381.  
  382.  
  383.     class Link {
  384.         int a[] = new int[1000000];
  385.         Link l;
  386.     }
  387.     class OutOfMem {
  388.         public static void main(String args[]) {
  389.             Link root = new Link();
  390.             Link cur = root;
  391.             while(true) {
  392.                 cur.l = new Link();
  393.                 cur = cur.l;
  394.             }
  395.         }
  396.     }
  397.  
  398.  
  399.  
  400. NoClassDefFoundException
  401.  
  402. A NoClassDefFoundException is thrown if a class is referenced but the runtime system cannot find the referenced class. 
  403.  
  404. For example, class NoClass is declared:
  405.  
  406.  
  407.  
  408.  
  409.     class NoClass {
  410.         public static void main(String args[]) {
  411.             C c = new C();
  412.         }
  413.     }
  414.  
  415.  
  416.  
  417. When NoClass is run, if the runtime system can't find C.class it throws the NoClassDefFoundException.
  418.  
  419. C.class must have existed at the time NoClass is compiled.
  420.  
  421. IncompatibleTypeException
  422.  
  423. An IncompatibleTypeException is thrown if an attempt is made to instantiate an interface. For example, the following code causes an IncompatibleTypeException to be thrown.
  424.  
  425.  
  426.  
  427.  
  428.     interface I {
  429.     }
  430.  
  431.     class IncompType {
  432.         public static void main(String args[]) {
  433.             I r = (I)new("I");
  434.         }
  435.     }
  436.  
  437.  
  438.  
  439. ArrayIndexOutOfBoundsException
  440.  
  441. An attempt to access an invalid element in an array throws an ArrayIndexOutOfBoundsException. For example:
  442.  
  443.  
  444.  
  445.  
  446.     class ArrayOut {
  447.         public static void main(String args[]) {
  448.             int a[] = new int[0];
  449.             a[0] = 0;
  450.         }
  451.     }
  452.  
  453.  
  454.  
  455. UnsatisfiedLinkException
  456.  
  457. An UnsatisfiedLinkException is thrown if a method is declared native and the method cannot be linked to a routine in the runtime. 
  458.  
  459.  
  460.  
  461.  
  462.     class NoLink {
  463.         static native void foo();
  464.  
  465.         public static void main(String args[]) {
  466.             foo();
  467.         }
  468.     }
  469.  
  470.  
  471.  
  472. InternalException
  473.  
  474. An InternalException should never be thrown. It's only thrown if some consistency check in the runtime fails. Please send mail to 
  475. WebRunner@Sun.COM if you have a reproducible case that throws this exception. 
  476.  
  477.  
  478.